Skip to content

Conversation

@adammil2000
Copy link

@adammil2000 adammil2000 commented Sep 4, 2025

Fix incorrect Python libraries

Description

Fixes #

Note: Before submitting a pull request, please open an issue for discussion if you are not associated with Google.

Checklist

Fix incorrect Python libraries
@adammil2000 adammil2000 requested review from a team as code owners September 4, 2025 20:04
@snippet-bot
Copy link

snippet-bot bot commented Sep 4, 2025

No region tags are edited in this PR.

This comment is generated by snippet-bot.
If you find problems with this result, please file an issue at:
https://github.com/googleapis/repo-automation-bots/issues.
To update this comment, add snippet-bot:force-run label or use the checkbox below:

  • Refresh this comment

@product-auto-label product-auto-label bot added samples Issues that are directly related to samples. api: cloudfunctions Issues related to the Cloud Run functions API. labels Sep 4, 2025
Copy link
Contributor

@gemini-code-assist gemini-code-assist bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Summary of Changes

Hello @adammil2000, I'm Gemini Code Assist1! I'm currently reviewing this pull request and will post my feedback shortly. In the meantime, here's a summary to help you and other reviewers quickly get up to speed!

This pull request updates the Python dependencies for the functions/billing module by modifying its requirements.txt file. The change ensures that the function relies on the correct and modern set of libraries, specifically for cloud event handling, function execution, and Google Cloud billing and logging services, thereby improving the function's operational integrity and alignment with current best practices.

Highlights

  • Dependency Correction: The pull request addresses and fixes incorrect Python library dependencies for a specific function.
  • Library Update: It updates the requirements.txt file for the functions/billing module, replacing outdated or irrelevant libraries with current and necessary ones.
  • Specific Libraries Changed: slackclient and google-api-python-client are removed, and cloudevents, functions-framework, google-cloud-billing, and google-cloud-logging are added with specified versions.
Using Gemini Code Assist

The full guide for Gemini Code Assist can be found on our documentation page, here are some quick tips.

Invoking Gemini

You can request assistance from Gemini at any point in your pull request via creating an issue comment (i.e. comment on the pull request page) using either /gemini <command> or @gemini-code-assist <command>. Below is a summary of the supported commands.

Feature Command Description
Code Review /gemini review Performs a code review for the current pull request in its current state.
Pull Request Summary /gemini summary Provides a summary of the current pull request in its current state.
Comment @gemini-code-assist Responds in comments when explicitly tagged, both in issue comments and review comments.
Help /gemini help Displays a list of available commands.

Customization

To customize Gemini Code Assist for GitHub experience, repository maintainers can create a configuration file and/or provide a custom code review style guide (such as PEP-8 for Python) by creating and adding files to a .gemini/ folder in the base of the repository. Detailed instructions can be found here.

Limitations & Feedback

Gemini Code Assist may make mistakes. Please leave feedback on any instances where its feedback is incorrect or counter productive. You can react with 👍 and 👎 on @gemini-code-assist comments. If you're interested in giving your feedback about your experience with Gemini Code Assist for Github and other Google products, sign up here.

You can also get AI-powered code generation, chat, as well as code reviews directly in the IDE at no cost with the Gemini Code Assist IDE Extension.

Footnotes

  1. Review the Privacy Notices, Generative AI Prohibited Use Policy, Terms of Service, and learn how to configure Gemini Code Assist in GitHub here. Gemini can make mistakes, so double check it and use code with caution.

Copy link
Contributor

@gemini-code-assist gemini-code-assist bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Code Review

This pull request updates the requirements.txt file, replacing the existing Python libraries with a new set of dependencies. However, these new libraries are incompatible with the current implementation in main.py, which will cause ImportError exceptions and break the function. A critical review comment has been added to highlight this issue, suggesting either reverting the changes or including the necessary code modifications in main.py to use the new dependencies.

Comment on lines 1 to 4
cloudevents==1.10.1
functions-framework==3.5.0
google-cloud-billing==1.18.1
google-cloud-logging==3.9.0
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

critical

The updated dependencies are inconsistent with the imports in main.py. The existing code imports googleapiclient and slack, which are provided by google-api-python-client and slackclient respectively. These dependencies have been removed, which will cause ImportError exceptions and break the function.

The newly added dependencies (cloudevents, functions-framework, google-cloud-billing, google-cloud-logging) are not used in main.py.

Additionally, the region tags (# [START ...] and # [END ...]) have been removed. These are often important for documentation generation and code samples.

If the goal is to migrate to newer client libraries, the code in main.py must be updated as part of this PR. Otherwise, the previous dependencies should be restored to ensure the function remains operational.

slackclient==2.9.4
# [START functions_billing_limit_appengine_deps]
google-api-python-client==2.131.0
# [END functions_billing_limit_appengine_deps]

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@adammil2000 thanks for your contribution but this isn't going to work as expected as gemini-code-assist is sharing. What are you trying to fix?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I agree with @iennae. The changes in requirements.txt appear to be incompatible with the existing main.py file. Could you please clarify the intended purpose of this pull request, @adammil2000? Understanding the goal will help determine the correct set of dependencies and necessary code changes.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

In this doc page:

https://cloud.google.com/billing/docs/how-to/disable-billing-with-notifications#create-cloud-run-function

we had a report from one of the devs that the libraries indicated on this page are missing these required ones (updated to use wildcards):

cloudevents==1.10.1
google-cloud-billing==1.*
google-cloud-logging==3.*

I suspect we don't need the slack dependency either.

But I am unfamiliar with the process to get these github repo samples updated so they reflect correctly in the docs. Also I don't see main.py discussed on this doc page, so that threw me a bit about what to do with that one.

Thanks!

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@adammil2000 Got it! Apologies for the delay. I think the problem is you want to pull this requirements file https://github.com/GoogleCloudPlatform/python-docs-samples/blob/e6d1b6c547ee4c9c115be05acc61d8f55a0b2a3c/functions/billing_stop_on_notification/requirements.txt for the documentation and not this one.

@glasnt glasnt added the waiting-response Waiting for the author's response. label Sep 11, 2025
Copy link
Author

@adammil2000 adammil2000 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Replaced missing dependency block and fixed typo for billing to 1.16.1

Comment on lines 1 to 4
cloudevents==1.10.1
functions-framework==3.5.0
google-cloud-billing==1.18.1
google-cloud-logging==3.9.0
Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

In this doc page:

https://cloud.google.com/billing/docs/how-to/disable-billing-with-notifications#create-cloud-run-function

we had a report from one of the devs that the libraries indicated on this page are missing these required ones (updated to use wildcards):

cloudevents==1.10.1
google-cloud-billing==1.*
google-cloud-logging==3.*

I suspect we don't need the slack dependency either.

But I am unfamiliar with the process to get these github repo samples updated so they reflect correctly in the docs. Also I don't see main.py discussed on this doc page, so that threw me a bit about what to do with that one.

Thanks!

@glasnt glasnt removed the waiting-response Waiting for the author's response. label Oct 16, 2025
@iennae
Copy link
Contributor

iennae commented Oct 17, 2025

@adammil2000 thanks for the details. I've gone ahead and made a new region tag and opened a PR here #13610

Please update your source documents with functions_billing_stop_requirements

@iennae iennae closed this Oct 17, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

api: cloudfunctions Issues related to the Cloud Run functions API. samples Issues that are directly related to samples.

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants